<template>
  <div>
    <h3 class="title">{{ photoinfo.title }}</h3>

    <p class="info">
      <span>发表时间：{{ photoinfo.add_time | dateFormat }}</span>
      <span>点击：{{ photoinfo.click }}次</span>
    </p>

    <hr>

    <!-- 缩略图区域 -->
    <div class="thumb-img-list">
      <!-- 使用 v-for 循环渲染缩略图 -->
      <img class="preview-img" v-for="(item, index) in photolist" :src="item.src" height="100" @click="$preview.open(index, photolist)" :key="index">
    </div>

    <!-- 内容区域 -->
    <div class="content" v-html="photoinfo.content"></div>

    <!-- 评论子组件 -->
    <!-- 注意：在使用评论子组件的时候，人家必须要接收一个 newsid 的属性 -->
    <comment :newsid="id"></comment>

    <br>
    <br>
    <br>
  </div>
</template>

<script>
  // 导入评论组件 
  import comment from '../sub-conponents/Comment.vue'

 /*  // 导入 MUI 缩略图相关脚本
  import '../../../lib/mui/js/mui.js'
  import '../../../lib/mui/js/mui.zoom.js'
  import '../../../lib/mui/js/mui.previewimage.js' */

  export default {
    data(){
      return {
        photoinfo: {}, // 图片信息
        photolist: []
      }
    },
    created(){
      this.getPhotoInfo()
      this.getThumbImg()
    },
    methods: {
      async getPhotoInfo() {
        // 当调用一个异步方法，同时，这个异步方法的返回值是 Promise 对象的时候，才可以使用 await 和 async
        const { data } = await this.$http.get('/api/getimageInfo/'+ this.id)
        if(data.status === 0) return (this.photoinfo = data.message[0])
      },
        async getThumbImg() {
          // 获取图片的缩略图数据
          const { data } = await this.$http.get("/api/getthumimages/" + this.id);
          if (data.status === 0) {
            //  为 每一张图片设置 宽和高
            data.message.forEach(item => {
              item.w = 600;
              item.h = 400;
            });
            this.photolist = data.message;
          }
        }
    },
    props: ['id'],
    components:{
      comment
    }
    
}
</script>


<style lang="scss" scoped>
.photoinfo-container {
  padding: 3px;
}
.title {
  font-size: 15px;
  text-align: center;
  margin: 15px 0;
  color: #26a2ff;
}
.info {
  font-size: 13px;
  display: flex;
  justify-content: space-between;
}
.content {
  font-size: 13px;
  line-height: 30px;
}

.thumb-img-list {
  img {
    margin: 10px;
    box-shadow: 0 0 7px gray;
  }
}
</style>